草庐IT

MySQL PRIMARY KEY 与 UNIQUE 约束

全部标签

c# - 在 Entity Framework 中使用唯一约束交换值

我对Navigations表的名为Index的列有唯一约束。我有两个Navigation实体,我想交换它们的Index值。当我调用db.SaveChanges时,它会抛出一个异常,表明违反了唯一约束。似乎EF正在更新一个值,然后更新另一个值,因此违反了约束。难道不应该在事务中同时更新它们,然后在整理出值且不违反约束后尝试提交吗?有没有不使用临时值的方法解决这个问题? 最佳答案 这不是EF的问题,而是SQL数据库的问题,因为update命令是顺序执行的。事务与此无关——所有约束都是按命令而不是按事务验证的。如果您想交换唯一值,您需要更

c# - 为什么在没有 new() 泛型类型约束的情况下允许 Activator.CreateInstance<T>() ?

在下面显示的示例代码中,“CompileError”方法不会编译,因为它需要whereT:new()CreateWithNew()中所示的约束方法。然而,CreateWithActivator()方法在没有约束的情况下编译得很好。publicclassGenericTests{publicTCompileError()//compileerrorCS0304{returnnewT();}publicTCreateWithNew()whereT:new()//buildsok{returnnewT();}publicTCreateWithActivator()//buildsok{ret

c# - 在 NUnit 2.5 中使用 Lambda 作为约束?

根据CharliePoole'sNUnitblog,在NUnit2.5中可以使用Lambda表达式作为约束。我似乎无法让它工作?我正在使用NUnit2.5.3.9345。使用博文中的示例lambda:[TestFixture]publicclassClass1{[Test]publicvoidsomeTest(){int[]array={1,2,3,4};Assert.That(array,Is.All.Matches((x)=>x%4==0&&x%100!=0||x%400==0));}}编译器的结果是:“无法将lambda表达式转换为类型‘NUnit.Framework.Const

c# - ASP.NET MVC 2 中具有约束的可选路由参数?

如果我有这样一条路线:routes.Add(newRoute("{controller}/{page}",newRouteValueDictionary{{"page",UrlParameter.Optional}},newRouteValueDictionary{{"page",@"[Pp]age\d+"}},newMvcRouteHandler()));然后当{page}丢失时路由不匹配,但是如果我删除约束它匹配。这是错误还是功能? 最佳答案 我在正则表达式中使用^$|,例如:(^$|[Pp]age\d+)。我在搜索此问题的答案

c# - 不能同时指定约束类和 0​​x104567910 或 'class' 约束

我正在尝试解决mockingissue通过创建IDbSet的自定义模拟。自定义模拟:publicclassDbSetMock:IDbSet{/*hiddenallotherimplementedmethods/properties*/publicTDerivedEntityCreate()whereTDerivedEntity:class,Tenant{thrownewNotImplementedException();}}create方法给出了一个构建错误,我不知道如何解决:cannotspecifybothaconstraintclassandthe'class'or'struct

c# - 对 Nullable<T> 约束的困惑

大家好。对不起,如果之前已经问过(徒劳地搜索)或者真的很简单,但我就是无法理解。MSDNdefinitionNullable类型的声明,它是按以下方式定义的:[SerializableAttribute]publicstructNullablewhereT:struct,new()所以问题很简单:这个定义怎么可能?或者这只是一个错字?每个值类型都有一个默认构造函数。事实上,当我尝试编译这样的东西时,编译器合理地说,同时应用两个约束是非法的,因为第二个约束隐式包含在第一个约束中。提前致谢。 最佳答案 我认为这只是文档中的一个错误。如果

c# - 为什么在测试受约束的泛型类型时直接转换失败但 "as"运算符成功?

``在编译一些使用具有类型约束的泛型的C#代码时,我遇到了一个有趣的好奇心。我写了一个快速测试用例来说明。我在VisualStudio2010中使用.NET4.0。namespaceTestCast{publicclassFruit{}publicclassApple:Fruit{}publicstaticclassTest{publicstaticvoidTestFruit(FruitTypefruit)whereFruitType:Fruit{if(fruitisApple){Appleapple=(Apple)fruit;}}}}转换为Apple失败并出现错误:“无法将类型‘Fr

c# - Curiously Recurring Template Pattern 和泛型约束 (C#)

我想在基泛型类中创建一个方法来返回派生对象的专门集合并对它们执行一些操作,如以下示例所示:usingSystem;usingSystem.Collections.Generic;namespacetest{classBase{publicstaticListDoSomething(){Listobjects=newList();//fillthelistsomehow...foreach(Ttinobjects){if(t.DoSomeTest()){//error!!!//...}}returnobjects;}publicvirtualboolDoSomeTest(){return

c# - Generics & Reflection - GenericArguments[0] 违反类型约束

我已经为这个问题绞尽脑汁了一段时间,本质上我是在尝试实现一个通用的存储库工厂,其名称如下:varresposFactory=newRepositoryFactory>();存储库工厂如下所示:publicclassRepositoryFactory:IRepositoryFactory{publicTGetRepository(GuidlistGuid,IEnumerablefieldMappings){AssemblycallingAssembly=Assembly.GetExecutingAssembly();Type[]typesInThisAssembly=callingAss

c# - Microsoft Solver foundation 与 Matlab fmincon 中的约束非线性优化

任何人都可以向我展示MicrosoftSolverfoundation3.0中约束非线性优化的示例或评论吗?与Matlab的fmincon相比如何?或者是否有更好的.net库用于约束非线性优化?谢谢, 最佳答案 2012年2月25日的重要更新:MSF3.1现在通过其NelderMeadSolver求解器支持使用有界变量的非线性优化:http://msdn.microsoft.com/en-us/library/hh404037(v=vs.93).aspx对于一般的线性约束,Microsoftsolverfoundation仅通过其内